/**
 * Created with IntelliJ IDEA.
 * Description:
 * User: mirac
 * Date: 2025-11-07
 * Time: 23:37
 */
public class Solution {
    public void merge(int[] nums1, int m, int[] nums2, int n) {
        //处理特殊情况
        if (m == 0) {
            for (int i = 0; i < n; i++) {
                nums1[i] = nums2[i];
            }
            return;
        }

        //当nums1和nums2都存在时
        int i = m-1;
        int j = n-1;
        int k = m+n-1;
        while (i >= 0 && j >= 0) {
            if (nums1[i] > nums2[j]) {
                nums1[k--] = nums1[i--];
            }else {
                nums1[k--] = nums2[j--];
            }
        }

        //如果nums1排完了，nums2还有
        while (j >= 0) {
            nums1[k--] = nums2[j--];
        }
    }
}
